home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Amiga Format CD 49
/
Amiga Format CD49 (2000-01-17)(Future Publishing)(GB)(Track 1 of 3)[!][issue 2000-02].iso
/
+system+
/
tools
/
gui
/
bgui12.lha
/
bgui.doc
< prev
next >
Wrap
Text File
|
1995-09-23
|
20KB
|
474 lines
`BGUI' release 1.2
******************
Preface
*******
`BGUI' release 1.2
(C) Copyright 1993-1995 Jaba Development
(C) Copyright 1993-1995 Jan van den Baard
Written using DICE v3.0 by
SNail: Jan van den Baard
Bakkerstraat 176
3082 HE Rotterdam
Holland
Fido: 2:286/407.53 (Jan van.den.Baard)
EMail: jaba@grafix.wlink.nl
EMail is preferred.
If you must use snail mail then please make it clear
when you absolutely need an anwser and (don't forget
this) include enough return postage.
User Manual
(C)Copyright 1993-1995 Jaba Development
__ __
/ / / \
__ / / / /\ \
_____\ \__/ /_/ /_/ /_____
(__________________________)
`BGUI', (C) Copyright 1993-1995 Jaba Development. All rights reserved. This
program is GiftWare. This means that if you want to use the programs you are
morally obligated to reward the author with a gift that, you think, matches
his efforts. If you cannot think of a gift (come on! be creative ;), a small
financial donation will always be gladly accepted.
I have thought about how to release this package for quite some time. My
initial thought went out to shareware but I soon forgot about this. Since most
of the libraries of this kind seem to be shareware I do not think that many
people like this simply because it's anoying to have to pay for a library if
you had to pay for the application as wel.
To avoid these problems I have decided to release this package as giftware
for people writing freely distributable software. With "freely distributable
software" I mean non-crippeled, free of charge software. Authors who wish to
use `BGUI' in shareware and/or commercial programs must pay for the usage of
`BGUI' before actually using it.
ShareWare and/or commercial usage is `not' allowed without:
1) Prior written permission from the author.
2) A small finacial donation of US$ 20,-, DM 30,- or HFL 30,-.
3) A free and registered copy of the product including free updates that
still make use of the library.
The idea behind this distribution policy is simple. You make money with the
aid of `BGUI'? I want to get my (very humble) share.
This software is not crippeled so when you register it you will not recieve
a key-file or an updated version. Registering simply buys you the right to use
this software in shareware and/or commercial applications.
Resonable, eh?
Introduction
************
`BGUI' is a BOOPSI based shared library contaning a number of BOOPSI
classes. It allows for easy creation and managing of font sensitive and size
adjustable GUI's on the Amiga. Hmm, where have I read something like this
before..., I hear you say.
YES! This is yet another GUI library. I know there has been a lot of
discussions about the usabillity and neccesity of GUI libraries on the nets
lately. Still, being the ignorant bugger that I am, at some point I felt it
was necessary to write yet another one.
Believe me when I say that `BGUI' was not intended to become a releasable
project. I started coding `BGUI' simply because I was amazed what MUI did
using BOOPSI. Therefore I started coding some BOOPSI classes as a learning
experience.
Hmmm... This is beginning to sound like an excuse... As if I did something
terrible ;)
The point is that, while working on BGUI, I saw many GUI libraries being
released and not one of them really seemed to take off. This made me think
that all this talk about "For every app I run I need to install a different
GUI library" really is bull. Please correct me if I'm wrong but I have yet to
see a program requiring a GUI library (with the exception of MUI ofcourse).
Sure there are a lot available but MUI is the only one which actually seems
to be used by the programmers.
This is the reason for `BGUI'. I have tryed to create a library which does
it's thing simular to MUI eliminating the biggest problems that programmers
seem to have with MUI. Meaning no fancy
background-pen-frame-text-image-whatever settings editor, not a zillion extra
images, no external class libraries etc.
`BGUI' is a single library which can be removed as easely as it can be
installed. It provides an easy way to create and control GUI's without becoming
excessive in what it does.
I guess time will tell if `BGUI' is going to be accepted or not...
Features
********
* Requires at least OS 2.04 (Yes, that is a feature :)
* Extends on the existing system gadgetclass and rootclass.
* Creates completely font sensitive GUI's.
* Supports sizable windows.
* AppWindow support.
* Titled group-frames and seperators.
* Supports OS 3.0 when available.
* Style Guide compliant.
* Keyboard control of most gadget classes.
* Several types of notification to create "self driven" GUI's.
* Easy intergration of third-party classes.
* Easy to make your class work directly with BGUI.
* Object oriented.
* Resonable speed, even with a 68000 processor.
* Relatively small library.
* Classes for easy filerequester and commodity creation.
* Seperate ARexx class including source code.
Requirements
************
`BGUI' requires at least version 2.04 of the operating system. It does `not'
run on 1.3 systems. Are there still people running 1.3?
`BGUI' also requires the following disk-based libraries to operate:
* gadtools.library (V37) (menus)
* asl.library (V37) (filereq class)
* commodities.library (V37) (commodities class)
The following libraries are not required but they will impose on the
functionality of the library when not available:
* locale.library (V38) (localized library strings)
* amigaguide.library (V37) (On-line help)
* workbench.library (V37) (App-window support)
It should not be a problem to use BGUI on a system with 512KByte but a
minimum of 1 Megabyte is suggested as a minimum.
Installation
************
The installation of BGUI is very simple. You can either use the Installer
utility by C= which will install the library for you or you can copy the
`bgui.library' to your LIBS: directory or into a directory you might have
setup for non-system libraries.
Where you put the headers/modules for the language you use is up to you.
Since the different compilers and users use different directory structures I
did not supply a script for you to install these. You'll have to do this by
hand.
Read Me
*******
* The bgui.library is a special library in the sence that it is a single
task library. This means that `every' task using the library must open
the library for itself. The library base pointer may `not' be shared
between different tasks.
The reason for this is that the library tracks information like window
bounds etc. This tracking is done for each individual task.
So if your code spawns a sub-task which needs the library, the sub-task
code must open the library for itself. It may not share it with the main
task.
* The object ID's (gadgets and menus) are restricted to the range 1..65535.
ID's smaller or larger than this are not allowed. This should not be a
problem :)
* When designing custom classes to work with BGUI please try to keep your
tag values and method ID's well out of the range of the BGUI tag values
and method ID's. Using values that conflict with the BGUI values may have
unexpected results.
* Do not be alarmed when you notice disk-activity when a BGUI requester
pops up. This is due to the fact that the bgui.library catalog file is
re-loaded each time BGUI needs it. This makes sure that the language is
correct if it changed.
* When scrolling a large listview the mouse pointer may move in steps
rather than smoothly. This is not abnormal behaviour with BOOPSI objects
because all rendering occures on the input device it's task. Just scroll
a MultiView window with the scroller and you'll see the same effect.
* The BGUI windowclass depends on the IDCMP_SIZEVERIFY flag. This means
that the responce to the signals you get have to be as quick as possible.
If you need to use DOS routines or are unable to call uppon the
windowclass event handler for a while you need to switch of the
IDCMP_SIZEVERIFY dependance before you do and back on after you're done.
There is a tag called WINDOW_NoVerify for this.
Keyboard & Mouse
****************
Most of the BGUI gadget objects can be controlled by the keyboard. Usually
the key that is used to control an object is shown by an underlined character
in the object it's label. The objects can be controlled as follows:
* `Button' - Pressing the key will make the object appear pressed. If you
release the key the object appears normal again and the application is
signalled that the object was selected. When you accidentally activated
the button you can press SHIFT or ESC before releasing the key to cancel
the selection.
* `Toggle Button' - Pressing the key will toggle the selected state of the
toggle button.
* `CheckBox' - Pressing the key will toggle the selected state of the
checkbox object.
* `Prop (Scroller)' - Pressing the key will advance the knob position by
one page. When you press the key together with SHIFT the knob will backup
one page. You can reset the knob position when you are dragging the knob
with the mouse by clicking on the right mouse button.
* `Listview' - Pressing the key will select the next entry in the list
scrolling the entries when necessary. Pressing the key together with
SHIFT will select the previous entry. Read only listview objects will
simply scroll the list forward and backward.
* `Cycle' - Pressing the key will cycle one choise forward. Pressing the
key together with SHIFT will cycle one choise backward. Selecting the
gadget with the mouse while holding down the SHIFT key will also make the
gadget cycle backward. When the cycle gadget was setup to be a popup
gadget by the application programmer you can click inside the label area
to pop-up a menu from which you can select the desired item. You can
recognize a popup gadget by the imagery left of the label area. Normal
cycle gadgets have a circular arrow here and popup gadgets have a small
menu here.
* `Slider' - Pressing the key will advance the knob position by one.
Pressing the key together with shift will decrease the knob position by
one. You can reset the knob position when you are dragging the knob with
the mouse by clicking to on the right mouse button.
* `String,Integer' - Pressing the key will simply activate the gadget.
* `Mx' - Pressing the key will select the next button skipping any disabled
buttons. Pressing the key together with shift will select the previous
button skipping any disabled buttons. If the Mx object is in tabs mode
the choises will not stop at the last or first selection but instead it
will cycle back to the start or the end.
As you can see this behaviour is mostly style guide compliant with some
additional possibilities.
Disclaimer
**********
THERE IS NO WARRANTY FOR THE PROGRAMS, TO THE EXTENT PERMITTED BY
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS
AND/OR OTHER PARTIES PROVIDE THE PROGRAMS "AS IS" WITHOUT WARRANTY OF ANY
KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE
ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAMS IS WITH YOU.
SHOULD THE PROGRAMS PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY
SERVICING, REPAIR OR CORRECTION.
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL
ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY REDISTRIBUTE THE PROGRAMS AS
PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL,
INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE
THE PROGRAMS (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED
INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE
PROGRAMS TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER
PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
License
*******
This license applies to the product called `BGUI', a program for the Amiga
computer, published by Jan van den Baard under the concepts of GiftWare, and
the accompanying documentation, example files and anything else that comes
with the original distribution. The term "Program" below, refer to this
product. The term "Author" below, refers to "Jan van den Baard". The license
is addresses as "you".
* You may copy and distribute verbatim copies of the program's executable
code and documentation as you receive it, in any medium, provided that
you conspicuously and appropriately publish only the original, unmodified
program, with all copyright notices and disclaimers of warranty intact
and including all the accompanying documentation, example files and
anything else that came with the original.
* You may not copy and/or distribute this program without the accompanying
documentation and other additional files that came with the original. You
may not copy and/or distribute modified versions of this program.
* You may not copy, modify, sublicense, distribute or transfer the program
except as expressly provided under this license. Any attempt otherwise
to copy, modify, sublicense, distribute or transfer the program is void,
and will automatically terminate your rights to use the program under
this license. However, parties who have received copies, or rights to
use copies, from you under this license will not have their licenses
terminated so long as such parties remain in full compliance.
* By copying, distributing and/or using the program you indicate your
acceptance of this license to do so, and all its terms and conditions.
* Each time you redistribute the program, the recipient automatically
receives a license from the original licensor to copy, distribute and/or
use the program subject to these terms and conditions. You may not
impose any further restrictions on the recipients' exercise of the rights
granted herein.
* You may not disassemble, decompile, re-source or otherwise reverse
engineer the program.
* You are free to use the programs. If, after an evaluation period of up to
30 days, you find the programs useful enough to continue using them you
are morally, not lawfully, obligated to send the author a gift that, you
think, matches his efforts. Shareware or commercial usage of the programs
require registering. Please refer to the *note Preface::. section for
more information on registering.
* If you wish to incorporate parts of the programs into other programs,
write to the author to ask for permission. If you want to release your
programs as being Public Domain, FreeWare or GiftWare you are allowed to
include a copy of the "bgui.library" without the accompaning
documentation and files. ShareWare and Commercial distribution of the
programs is not allowed without prior written permission. Please refer to
the *note Preface::. section for more information on registering.
* You agree to cease distributing the program and data involved if
requested to do so by the author.
* You may charge a fee to recover distribution costs. The fee for diskette
distribution may not be more than the cost to obtain a public domain
diskette from Fred Fish.
Future
******
This is a list of known bugs and quirks. Please read this before you start
sending me bug reports and suggestions.
`BUG' = A bug that is still present.
`SUG' = A suggestion which might be implemented in the future.
`REV' = Revision and/or fine-tuning that still needs to be done.
`MAY' = Maybe...
* `BUG' - The layout engine locks up when, due to a bug or hacking, you
re-size a window smaller than it's minimum as decided by BGUI. Reported
by Florian Vorberger.
* `BUG' - The infoclass screws up computing it's minimum dimensions when
the last thing in the text is a command sequence. Should not be a real
problem since it is bullshit to end a string with a command sequence.
* `BUG' - There seem to be problems when using the textfield.gadget in a
BGUI context. The problem is that if you select an object while the
textfield object is active you get a double message from the clicked
object. I do not know why this is happening.
* `REV' - `BGUI' gadgets on intuition requesters is `NOT' supported yet.
* `REV' - The commodity class could use some cleaning up. I'm not really
satisfied with it as it is.
* `REV' - The format of the library and class documentation files suck. I
should convert them to "real" autodoc format or amigaguide files.
* `REV' - Error reporting. It's OK that a window failed to open or an
object failed to create but it would be nice to know why. Both numeric
and textual error descriptions should be made available.
* `REV' - Adding method, conditional and hook notification to the window
class to. This will allow notification to happen on the application task
instead of the input.device task.
* `REV' - Work on the menus. For now it is not possible to dynamically add
items, add notification or help files to the menus. This really sucks.
* `REV' - Try to cut down on the code size. Although, all things
considering, BGUI is not excessive in size I'de like to see it smaller.
* `MAY' - Letting the window backfill hook optionally make use of the
preferred workbench window backfill pattern or picture.
* `MAY' - Fonts and images in the info class.
* `MAY' - Add a posibility to "snapshot" window sizes to disk. Should this
be up to the application programmer? Suggested by Paul Weterings.
* `MAY' - Take the layout engine of BGUI and make a seperate shared/link
library out of it. This would result in a +/- 10 KByte shared/link
library with the same functionality as the BGUI layout engine. Maybe this
will satisfy those people who are always bitching and complaining about
GUI engine libraries.
Thanks To
*********
The author would like to extend a big thank you to the following people for
their valuable help:
Bjorn Reese, Jim Cooper, Jim Karczewski, Keith Christopher, Michael
Wiedmer, Michiel Willems, Magne Oestlyngen, Magnus Enarsson, Martin Bischoff,
Parrish Heywood, Patrick van Beem, Paul Hill, Paul McLachlan, Paul Weterings,
Per Harald Myrvang, Ranulf Doswell, Zachary A Forsyth.
And the people I may have forgotten...
Thanks should also go to:
* Gary Duncan, Heiko Rath and Boris Jakubaschk for giving me permission to
use their SCSI-2 code for the BGUIPlayer demo program.
* All the folks at `O.I.C'. Obvious Implementations Corporation. This
software is completely developed using DICE in the registered version and
later on the commercial version.
* Francesco Devitt for MemLeak. A remarkable simple but very useful tool ;)
* Reinhard Spisser and Sebastiano Vigna for their wonderful Makeinfo which
was used to generate this AmigaGuide./ASCII documentation.
* Bryce Nesbitt and Michael Sinz for Enforcer. The best bug-hunter for the
Amiga.
Index
*****
* Menu:
* Disclaimer: Disclaimer.
* Features: Features.
* Future: Future.
* Installation: Installation.
* Introduction: Introduction.
* Keyboard & Mouse: Keyboard & Mouse.
* License: License.
* Preface: Preface.
* Read Me: Read Me.
* Requirements: Requirements.
* Thanks To: Thanks To.